$(function() {
    var form = layui.form
    var layer = layui.layer
        // 获取文章分类信息
    initCate()

    function initCate() {
        $.ajax({
            type: 'get',
            url: '/my/article/cates',
            success: function(res) {
                if (res.status !== 0) {
                    return
                }
                // 渲染到页面
                var htmlStr = template('tpl-cate', res)
                $('[name=cate_id]').html(htmlStr)
                    //更新全部
                form.render()
            }
        })

    }

    // 1. 初始化图片裁剪器
    var $image = $('#image')

    // 2. 裁剪选项
    var options = {
        aspectRatio: 400 / 280,
        preview: '.img-preview'
    }

    // 3. 初始化裁剪区域
    $image.cropper(options)

    // 点击‘选择封面’，弹出文件选择框
    $('#btnChooseImage').on('click', function() {
        $('#coverFile').click()
    })
    $('#coverFile').on('change', function() {
        // 1. 拿到用户选择的文件
        var file = $(this)[0].files
            // 判断是否选择了文件
        if (file.length === 0) {
            return
        }
        // 2. 根据选择的文件， 创建一个对应的 URL 地址：
        var newImgURL = URL.createObjectURL(file[0])
            // 3. 先销毁旧的裁剪区域， 再重新设置图片路径， 之后再创建新的裁剪区域：
        $image
            .cropper('destroy') // 销毁旧的裁剪区域
            .attr('src', newImgURL) // 重新设置图片路径
            .cropper(options) // 重新初始化裁剪区域
    })

    // 准备文章发布状态
    var state = '已发布'
        // 点击存为草稿，改变state
    $('#btnSave2').on('click', function() {
        state = '草稿'
    })

    // 发布文章
    $('#form-pub').on('submit', function(e) {
        e.preventDefault()
        var fd = new FormData($(this)[0])
            // 追加文章状态
        fd.append('state', state)

        // 裁剪图片 二进制文件
        $image
            .cropper('getCroppedCanvas', { // 创建一个 Canvas 画布
                width: 400,
                height: 280
            })
            .toBlob(function(blob) { // 将 Canvas 画布上的内容，转化为文件对象
                // 得到文件对象后，进行后续的操作 
                // 裁剪完后得到对象，调用此函数
                fd.append('cover_img', blob)
                    // 发送请求
                publish(fd)
            })
    })

    function publish(fd) {
        $.ajax({
            type: 'post',
            url: '/my/article/add',
            data: fd,
            contentType: false,
            processData: false,
            success: function(res) {
                if (res.status !== 0) {
                    return layer.msg(res.message)
                }
                layer.msg(res.message, function() {
                    // 跳转到文章列表页
                    // location.href = '/article/art_list.html'
                    // a标签，使用原生js实现点击事件，jquery方法实现不了，a标签的子元素可是使用jq方法
                    window.parent.document.querySelector('#jump').click()
                })
            }
        })
    }



})